<template>
  <div id="spaces-create" class="main-container container-fluid page-holder">
    <breadcrumb/>
    <el-row :gutter="30">
      <el-col :sm="6" class="title-container none-select">
        <div class="page-title-holder no-border-bottom">
          <h2 class="page-title">新建学习空间</h2>
        </div>
        <p>学习空间可以用于存放学习资料、心得体会，讨论问题等。</p>
      </el-col>
      <el-col :sm="18">
        <el-form ref="spacesCreateForm" label-position="top" :model="form" :rules="rules"
                 class="bold-label form-border m-t-16">
          <el-form-item label="空间名" prop="title" ref="title">
            <el-input v-model="form.title"/>
          </el-form-item>
          <el-form-item label="空间描述">
            <el-input v-model="form.desc" type="textarea" :autosize="{ minRows: 2 }"/>
          </el-form-item>
          <el-form-item label="空间封面">
            <div class="flex">
              <el-avatar :size="64" :src="previewAvatar" shape="square"/>
              <div class="body-line-height m-l-16">
                <div class="flex">
                  <UploadAvatar :preview-url.sync="form.avatar" v-on:avatar="setAvatar" />
                  <el-button size="small" class="m-l-10" @click="setAvatar({})">重置</el-button>
                </div>
                <p class="info">仅支持 jpg, jpeg, png 格式的图片类型。<br>图片允许的最大大小为2MB。</p>
              </div>
            </div>
          </el-form-item>
          <el-form-item label="访问权限">
            <el-radio-group v-model="form.public">
              <el-radio :label="true">公开</el-radio>
              <el-radio :label="false">私有</el-radio>
            </el-radio-group>
            <p class="body-line-height info m-l-16">
              <template v-if="form.public">
                - 允许所有人访问空间。
              </template>
              <template v-else>
                - 只允许空间成员访问空间，通过邀请链接添加空间成员；<br />
                - 不会出现在搜索结果中。
              </template>
            </p>
          </el-form-item>
          <el-form-item label="协议许可">
            <el-checkbox v-model="form.license">
              <div class="flex align-items-center">
                本空间下的资源均采用&nbsp;
                <el-tooltip effect="light" popper-class="tooltip-as-title">
                  <div slot="content">
                    许可要点：<br />
                    <ul class="p-l-16">
                      <li>使用他人作品时，须提到原作者</li>
                      <li>允许修改原作品；如果修改，须使用相同的许可证发布</li>
                    </ul>
                    <div class="flex flex-nowrap">
                      详细信息请参见<el-link type="primary" href="https://creativecommons.org/licenses/by-sa/4.0/deed.zh" target="_blank" style="font-size: 12px;">许可说明</el-link>。
                    </div>
                  </div>
                  <el-link
                    type="primary"
                    rel="license"
                    href="https://creativecommons.org/licenses/by-sa/4.0/deed.zh"
                    target="_blank"
                  >知识共享署名-相同方式共享 (by-sa) 4.0 国际许可协议</el-link>
                </el-tooltip>
                &nbsp;进行许可。
              </div>
            </el-checkbox>
          </el-form-item>
          <el-form-item>
            <el-button
              type="primary"
              @click="onSubmit"
              :loading="isLoading"
              :disabled="!form.license"
            >新建空间</el-button>
            <el-button @click="goBack">取消</el-button>
          </el-form-item>
        </el-form>
      </el-col>
    </el-row>
  </div>
</template>

<script>
import UploadAvatar from '@/components/shared/UploadAvatar';

export default {
  name: 'SpaceCreate', // 路由指向的空间创建页面
  components: { UploadAvatar },
  data() {
    return {
      form: {
        title: '', // 空间名
        desc: '', // 空间描述
        avatar: '', // 空间封面（url）
        avatarKey: undefined, // 封面key
        license: false, // 是否勾选协议
        public: true, // 空间是否公开
      },
      rules: {
        title: [{ required: true, validator: this.$va.spaceTitle, trigger: 'blur' }],
      },
      isLoading: false, // 正在创建空间
    };
  },
  computed: {
    previewAvatar() { return this.form.avatar || 'http://file.learnerhub.net/default_product_avatar.jpg'; },
  },
  methods: {
    // 创建空间
    onSubmit() {
      this.$refs.spacesCreateForm.validate((valid, errs) => {
        if (valid) {
          this.isLoading = true;
          this.$api.spaces.create(this.form)
            .then(res => this.$router.push({ path: `/${this.$rp.SPACES}/${res.data.id}` }))
            .catch(() => {})
            .then(() => { this.isLoading = false; });
        } else this.$refs[Object.keys(errs)[0]].$el.scrollIntoView({ block: 'center' });
      });
    },
    // 接受上传组件返回的头像数据
    setAvatar(avatar) {
      this.form.avatar = avatar.url;
      this.form.avatarKey = avatar.key;
    },
  },
};
</script>

<style></style>
